home *** CD-ROM | disk | FTP | other *** search
/ Chip 1998 September / CHIP Eylül 1998.iso / Slackwar / docs / Mail-HOWTO < prev    next >
Text File  |  1997-03-16  |  58KB  |  1,355 lines

  1.   The Linux Electronic Mail HOWTO
  2.   Guylhem Aznar <guylhem at danmark.linux.eu.org>
  3.   v2.0, January 1998
  4.  
  5.   This document describes the setup, care and feeding of Electronic Mail
  6.   (e-mail) under Linux.  You need to read this if you plan to communi¡
  7.   cate locally or to remote sites via electronic mail.  You probably do
  8.   *not* need to read this document if don't exchange electronic mail
  9.   with other users on your system or with other sites.
  10.  
  11.   1.  Introduction, copyright and standard disclaimer
  12.  
  13.   1.1.  Email and spamming
  14.  
  15.   First, convert all "at" in Emails address to "@".
  16.  
  17.   It's simple for humans, but not for bots searching the web to spam ;
  18.   therefore it's enough to protect generous contributors from being
  19.   spammed !
  20.  
  21.   1.2.  Goals
  22.  
  23.   The intent of this document is to answer some of the questions and
  24.   comments that appear to meet the definition of "frequently asked
  25.   questions" about e-mail software under Linux in general and the
  26.   version in the Linux Debian and RedHat distributions in particular.
  27.  
  28.   1.3.  New versions
  29.  
  30.   New versions of this document will be periodically posted to
  31.   comp.os.linux.announce, comp.answers and mail.answers.  They will also
  32.   be added to the various anonymous ftp sites who archive such
  33.   information including sunsite.unc.edu:/pub/Linux/docs/HOWTO.
  34.  
  35.   In addition, you should be generally able to find this document on the
  36.   Linux WorldWideWeb home page at http://sunsite.unc.edu/mdw/linux.html.
  37.  
  38.   1.4.  Feedback
  39.  
  40.   I am interested in any feedback, positive or negative, regarding the
  41.   content of this document via e-mail.  Definitely contact me if you
  42.   find errors or obvious omissions.
  43.  
  44.   I read, but do not necessarily respond to, all e-mail I receive.
  45.   Requests for enhancements will be considered and acted upon based on
  46.   that day's combination of available time, merit of the request and
  47.   daily blood pressure :-)
  48.  
  49.   Flames will quietly go to /dev/null so don't bother.
  50.  
  51.   Feedback concerning the actual format of the document should go to the
  52.   HOWTO coordinator : Greg Hankins (gregh at sunsite.unc.edu).
  53.  
  54.   1.5.  Copyright
  55.  
  56.   The Mail-HOWTO is copyrighted (c) 1998 Guylhem Aznar.  Distributed
  57.   under LDP copyright license.  If you have questions, please contact
  58.   Greg Hankins, the Linux HOWTO coordinator, at gregh at
  59.   sunsite.unc.edu.
  60.  
  61.   1.6.  Limited warranty
  62.  
  63.   Of course, I disavow any potential liability for the contents of this
  64.   document.  Use of the concepts, examples, and/or other content of this
  65.   document is entirely at your own risk.
  66.  
  67.   2.  Other sources of information
  68.  
  69.   2.1.  USENET
  70.  
  71.   There is nothing "special" about configuring and running mail software
  72.   under Linux (any more).  Accordingly, you almost certainly do *NOT*
  73.   want to be posting generic mail-related questions to the
  74.   comp.os.linux.*  newsgroups.
  75.  
  76.   Don't post in comp.os.linux hierarchy unless it's really linux
  77.   specific, for example : "Which options was Debian 1.2 sendmail
  78.   compiled with ?" or "RedHat 5.0 smail crashes when I run it".
  79.  
  80.   Let me repeat that.
  81.  
  82.   There is virtually no reason to post anything mail-related in the
  83.   comp.os.linux hierarchy any more.  There are existing newsgroups in
  84.   the comp.mail.* hierarchy to handle *ALL* your questions.
  85.  
  86.   IF YOU POST TO COMP.OS.LINUX.* FOR NON-LINUX-SPECIFIC QUESTIONS, YOU
  87.   ARE LOOKING IN THE WRONG PLACE FOR HELP.  THE MAIL EXPERTS HANG OUT IN
  88.   THE PLACES INDICATED ABOVE AND GENERALLY DO NOT RUN LINUX.
  89.  
  90.   POSTING TO THE LINUX HIERARCHY FOR NON-LINUX-SPECIFIC QUESTIONS WASTES
  91.   YOUR TIME AND EVERYONE ELSE'S AND IT FREQUENTLY DELAYS YOUR GETTING
  92.   THE ANSWER TO YOUR QUESTION.
  93.  
  94.   GOOD PLACES are :
  95.  
  96.              comp.mail.elm           the ELM mail system.
  97.              comp.mail.mh            The Rand Message Handling system.
  98.              comp.mail.mime          Multipurpose Internet Mail Extensions.
  99.              comp.mail.misc          General discussions about computer mail.
  100.              comp.mail.multi-media   Multimedia Mail.
  101.              comp.mail.mush          The Mail User's Shell (MUSH).
  102.              comp.mail.sendmail      the BSD sendmail agent.
  103.              comp.mail.smail         the smail mail agent.
  104.              comp.mail.uucp          Mail in the uucp environment.
  105.  
  106.   2.2.  Mailing Lists
  107.  
  108.   There are many sendmail, smail and qmail mailing lists.
  109.  
  110.   You can find addresses in /usr/doc/theoneyouhavechosen.
  111.  
  112.   2.3.  Other documents from LDP
  113.  
  114.   There is plenty of excellent material provided in the other Linux
  115.   HOWTO documents and from the Linux DOC project.
  116.  
  117.   In particular, you might want to take a look at the following:
  118.  
  119.   ╖  on your own computer in /usr/doc/smail or /usr/doc/sendmail :-)
  120.  
  121.   ╖  the Linux Networking Administrators' Guide
  122.  
  123.   ╖  the Serial Communications HOWTO
  124.  
  125.   ╖  the Ethernet HOWTO
  126.  
  127.   ╖  the UUCP HOWTO if you're fed via UUCP
  128.  
  129.   2.4.  Books
  130.  
  131.   The following is a non-inclusive set of books that will help:
  132.  
  133.   ╖  "Managing UUCP and USENET" from O'Reilly and Associates is in my
  134.      opinion the best book out there for figuring out the programs and
  135.      protocols involved in being a USENET site.
  136.  
  137.   ╖  "Unix Communications" from The Waite Group contains a nice
  138.      description of all the pieces (and more) and how they fit together.
  139.  
  140.   ╖  "Sendmail" from O'Reilly and Associates looks to be the definitive
  141.      reference on sendmail-v8 and sendmail+IDA.  It's a "must have" for
  142.      anybody hoping to make sense out of sendmail without bleeding in
  143.      the process.
  144.  
  145.   ╖  "The Internet Complete Reference" from Osborne is a fine reference
  146.      book that explains the various services available on Internet and
  147.      is a great source for information on news, mail and various other
  148.      Internet resources.
  149.  
  150.   ╖  "The Linux Networking Administrators' Guide" from Olaf Kirch of the
  151.      Linux Documentation Project is available on the net and is also
  152.      published by (at least) O'Reilly and SSC.
  153.  
  154.      It makes a fine one-stop shopping to learn about everything you
  155.      ever imagined you'd need to know about Unix networking.
  156.  
  157.   3.  Requirements
  158.  
  159.   3.1.  Hardware
  160.  
  161.   There are no specific hardware requirements for mail under Linux.
  162.  
  163.   You'll need some sort of 'transport' software to connect to remote
  164.   systems, which means either TCP/IP or uucp.
  165.  
  166.   This could mean that you need a modem or ethernet card, depending on
  167.   your setup.
  168.  
  169.   In most cases, you'll want the fastest modem you can afford, i.e. 57
  170.   600 bps currently.  In general, you want to have a 16550 UART on your
  171.   serial board or built into your modem to handle speeds of above 9600
  172.   baud.
  173.  
  174.   If you don't know what that last sentence means, please consult the
  175.   comp.dcom.modems group or the various fine modem and serial
  176.   communications FAQs and periodic postings on USENET.
  177.  
  178.   3.2.  Software
  179.  
  180.   Well, the problem is here. What shall you do with mail software ?
  181.  
  182.   1) Number of sites
  183.  
  184.   Feed more than 100 sites with complicated options for domain name ?
  185.   Choose sendmail !
  186.  
  187.   Feed less than 100 sites without playing with domain names too much ?
  188.   Choose smail !
  189.  
  190.   2) Security
  191.  
  192.   Feed more or less than 100 sites but with high security ?  Choose
  193.   qmail !
  194.  
  195.   Feed less than 100 sites but with a standard level of security ?
  196.   Choose smail !
  197.  
  198.   3) Different ways to receive mail
  199.  
  200.   Feed and being fed by UUCP or FIDO (via ifmail) ?  Feed and being fed
  201.   by POP and internet SMTP ?  Choose smail !
  202.  
  203.   Of course, feel free to choose any mail software, informations
  204.   provided here shall only help you in your choice. Sendmail is perfect
  205.   for many sites with complicated options, qmail is perfect for high
  206.   security ; inbetween sendmail and qmail is smail, the best compromise.
  207.   If you know what you're doing, choose sendmail (and you shouldn't be
  208.   reading a HOWTO !); otherwise I generally recommand smail.
  209.  
  210.   4.  Smail v3.1
  211.  
  212.   Smail3.1 seems to be a de-facto standard transport agent for uucp-only
  213.   sites and for some smtp sites. It's easy to configure, it compiles
  214.   without patching from the sources and it's fairly secure.
  215.  
  216.   4.1.  Configuring smail
  217.  
  218.   Install smail binary from your distribution (I recommand you choose
  219.   this) or get smail sources and build smail. If you're building smail
  220.   from sources, you need to have the following in your os/linux file so
  221.   that 'sed' gives you shell scripts that work properly.
  222.  
  223.   CASE_NO_NEWLINES=true
  224.  
  225.   Once it's installed, config. files will certainly go in /etc/smail
  226.   (but your mileage may vary if you use old distributions); let's start
  227.   editing them !
  228.  
  229.   4.2.  config" file
  230.  
  231.        # From
  232.        smart_path=polux
  233.        smart_transport=uux
  234.  
  235.        # To
  236.        hostname=danmark
  237.        domains=linux.eu.org
  238.  
  239.        visible_name=danmark.linux.eu.org
  240.        uucp_name=danmark.linux.eu.org
  241.  
  242.        # max_message_size=512k
  243.        # auth_domains=foo.bar
  244.        # more_hostnames=barberouge:barberouge.polux.freenix.fr
  245.  
  246.   Well, first, who is feeding you ? I'm fed by "polux" via uucp (i.e.
  247.   uux transport); naturally you need to change this file according to
  248.   your own situation. For example, you could by fed by
  249.   "bargw.bar.foobar.com" via "smtp", in that case you don't need a
  250.   transport file and can define "-transport_file " to indicate you don't
  251.   need one.
  252.  
  253.   You can also use "postmaster_address = yourname", hide the network
  254.   topology in outgoing addresses (if you're a gateway) using
  255.   "visible_name", set which aliases address can also be used for the
  256.   email you receive, using "more_hostnames".
  257.  
  258.   See smail documentation for more details or the examples in
  259.   /usr/doc/smail/examples to see if any match your situation.
  260.  
  261.   4.3.  directors" file
  262.  
  263.   # aliasinclude - expand ":include:filename" addresses produced by alias files
  264.   # This entry and the next one are pretty much boiler-plate.  Reasons
  265.   # for making significant changes are few.  The sole purpose of these
  266.   # is to match and expand addresses of the form:
  267.   #       :include:pathname
  268.   # which may occur in alias files or mailing-list/forward files
  269.   # (produced by any director with a driver of forwardfile).
  270.   aliasinclude:
  271.           driver = aliasinclude,          # use this special-case driver
  272.           nobody;                         # associate nobody user with addresses
  273.                                           #  when mild permission violations
  274.                                           #  are encountered
  275.           copysecure,                     # get permissions from alias director
  276.           copyowners,                     # get owners from alias director
  277.  
  278.   # forwardinclude - expand ":include:filename" addrs produced by forward files
  279.   forwardinclude:
  280.           driver = forwardinclude,        # use this special-case driver
  281.           nobody;
  282.           copysecure,                     # get perms from forwarding director
  283.           copyowners,                     # get owners from forwarding director
  284.  
  285.   # aliases - search for alias expansions stored in a database
  286.   # This is the standard aliases file.  It is used for generic things,
  287.   # like mapping root, postmaster, MAILER-DAEMON and uucp to site
  288.   # admins, creating some small system alias expansions, and such.  In
  289.   # this site configuration, the aliases file is used mostly for
  290.   # machine-specific aliasing/forwarding information.  Global forwarding
  291.   # information should be put in the "forward" database.
  292.   aliases:
  293.           driver=aliasfile,               # general-purpose aliasing director
  294.           -nobody,                        # all addresses are associated
  295.                                           # with nobody by default, so setting
  296.                                           # this is not useful.
  297.           sender_okay,                    # don't remove sender from expansions
  298.           owner=owner-$user;              # problems go to an owner address
  299.           file=/etc/aliases,
  300.           modemask=002,                   # should not be globally writable
  301.           optional,                       # ignore if file does not exist
  302.           proto=lsearch,                  # unsorted ASCII file
  303.  
  304.   # forward - search for expansions stored in a forwarding database
  305.   # This is the subdomain-wide user forwarding database.  Entries are
  306.   # maintained here for current or past users, to forward their mail to
  307.   # their preferred mail-reading machine.  The forward database is
  308.   # shipped around the TCP/IP network as changes are made, to keep the
  309.   # network consistent.
  310.   #forward:
  311.   #       driver = aliasfile,             # general-purpose aliasing director
  312.   #       -nobody,                        # all addresses are associated
  313.   #                                       # with nobody by default, so setting
  314.   #                                       # this is not useful.
  315.   #       owner = real-$user;             # problems go to an owner address
  316.   #
  317.   #       file = /etc/forward,
  318.   #       modemask = 002,
  319.   #       proto = dbm,                    # use dbm(3X) library for access
  320.  
  321.   # dotforward - expand .forward files in user home directories
  322.   # For users that have an entry in the "forward" database, a ".forward"
  323.   # file is only used if it is on the "home" machine, as identified in
  324.   # the forward database.  If used, it is treated as a list of addresses
  325.   # to which mail should be delivered, rather than (or in addition to)
  326.   # the user identified in the local address.
  327.   dotforward:
  328.           driver = forwardfile,           # general-purpose forwarding director
  329.           owner = postmaster, nobody, sender_okay;
  330.  
  331.           file = ~/.forward,              # .forward file in home directories
  332.           checkowner,                     # the user can own this file
  333.           owners = root,                  # or root can own the file
  334.           modemask = 002,                 # it should not be globally writable
  335.           caution = daemon:root,          # don't run things as root or daemon
  336.           # be extra carefull of remotely accessible home directories
  337.           unsecure = "~uucp:/tmp:/usr/tmp:/var/tmp"
  338.  
  339.   # forwardto - expand a "Forward to " in user mailbox files
  340.   # This emulates the V6/V7/System-V forwarding mechanism which uses a
  341.   # line of forward addresses stored at the beginning of user mailbox files
  342.   # prefixed with the string "Forward to "
  343.   forwardto:
  344.           driver = forwardfile,
  345.           owner = postmaster, nobody, sender_okay;
  346.  
  347.           file = /var/spool/mail/${lc:user},      # point at user mailbox files
  348.           forwardto,                      # enable "Forward to " function
  349.           checkowner,                     # the user can own this file
  350.           owners = root,                  # or root can own the file
  351.           modemask = 0002,                # under System V, group mail can write
  352.           caution = daemon:root           # don't run things as root or daemon
  353.  
  354.   # user - match users on the local host with delivery to their mailboxes
  355.   user:   driver = user;                  # driver to match usernames
  356.           transport = local               # local transport goes to mailboxes
  357.  
  358.   # real_user - match usernames when prefixed with the string "real-"
  359.   # This is useful for allowing an address which explicitly delivers to a
  360.   # user's mailbox file.  For example, errors in a .forward file expansion
  361.   # could be delivered here, or forwarding loops between multiple machines
  362.   # can be resolved by using a real-username address.  Also, users that
  363.   # wish to use mail as a means of transferring data to a machine that
  364.   # is not their "home" machine can mail to real-login-name@remote.host.
  365.   real_user:
  366.           driver = user;
  367.           transport = local,
  368.           prefix = "real-"                # for example, match real-root
  369.  
  370.   # lists - expand mailing lists stored in a list directory
  371.   # mailing lists can be created simply by creating a file in the
  372.   # /etc/smail/lists directory.
  373.   lists:  driver = forwardfile,
  374.           caution,                        # flag all addresses with caution
  375.           nobody,                         # and then associate the nobody user
  376.           owner = owner-$user;            # system V sites may wish to use
  377.                                           # o-$user, as owner-$user may be
  378.                                           # too long for a 14-char filename.
  379.           file = lists/${lc:user}         # lists is under $smail_lib_dir
  380.  
  381.   # owners - expand mailing lists stored in a list owner directory
  382.   # mailing lists owner lists can be created simply by creating a file
  383.   # in the /etc/smail/lists/owner directory.  Mailing list owners
  384.   # are sent locally generated errors dealing with a mailing list of the
  385.   # same name.  To create an owner list for a mailing list, create a
  386.   # file with the name of the list in /etc/smail/lists/owner.  This
  387.   # will create a list address of owner-listname, as is used by the
  388.   # "lists" director above.
  389.   owners: driver = forwardfile,
  390.           caution,                        # flag all addresses with caution
  391.           nobody,                         # and then associate the nobody user
  392.           owner = postmaster;             # system V sites may wish to use
  393.                                           # o-$user, as owner-$user may be
  394.                                           # too long for a 14-char filename.
  395.           prefix = "owner-",
  396.           file = lists/owner/${lc:user}   # lists is under $smail_lib_dir
  397.  
  398.   # request - expand mailing lists stored in a list request directory
  399.   # mailing lists request lists can be created simply by creating a file
  400.   # in the /etc/smail/lists/request directory.  Request addresses
  401.   # are typically used as a standard address for queries about a mailing
  402.   # list.  For example, requests for additions or deletions to a list
  403.   # will generally be sent to "list-request", which should be set up to
  404.   # forward to the appropriate person or persons.
  405.   request: driver = forwardfile,
  406.           caution,                        # flag all addresses with caution
  407.           nobody,                         # and then associate the nobody user
  408.           owner = postmaster;             # system V sites may wish to use
  409.                                           # o-$user, as owner-$user may be
  410.                                           # too long for a 14-char filename.
  411.           suffix = "-request",
  412.           file = lists/request/${lc:user} # lists is under $smail_lib_dir
  413.  
  414.   You shouldn't need to change anything here, only mailing list options
  415.   if you intend to run some using smail, or forwards options if, for
  416.   example, you want to disable forwarding.
  417.  
  418.   4.4.  fidopaths" file
  419.  
  420.   Create such a file only if you're using ifmail and FIDO.
  421.  
  422.   4.5.  routers" file
  423.  
  424.   # forces - force certain paths
  425.   # This database exists as a means of hardcoding the paths to various
  426.   # machines or domains.  It is for use in creating temporary tweaks to
  427.   # the other routint databases.  To change the database, edit the file
  428.   # maps/force.path and type "make" in the maps/ subdirectory.
  429.   forces:
  430.           driver = pathalias,             # router to search paths file
  431.           method = /etc/smail/maps/table; # transports are in this file
  432.           file = forcepaths,              # file containing force path info
  433.           proto = lsearch,                # use the sorted path file
  434.           optional,
  435.           reopen                          # close when not being used
  436.  
  437.   uucp_neighbors:
  438.           driver=uuname,                  # use a program which returns neighbors
  439.           transport=uux;
  440.           cmd="/usr/bin/uuname -a",       # specifically, use the uuname program
  441.   #        domain=uucp                    # strip ending ".uucp"
  442.  
  443.   # smart_host - a partically specified smarthost director
  444.   # If the config file attribute smart_path is defined as a path from the
  445.   # local host to a remote host, then hostnames not matched otherwise will
  446.   # be sent off to the stated remote host.  The config file attribute
  447.   # smart_transport can be used to specify a different transport.
  448.   # If the smart_path attribute is not defined, this router is ignored.
  449.   smart_host:
  450.           driver = smarthost,             # special-case driver
  451.           transport = uux                 # by default deliver over UUCP
  452.   #       path=phreak
  453.  
  454.   # ifmail - to send mails to fidonet and vice versa
  455.   ifmail:
  456.           driver=pathalias,
  457.           transport=ifmail;
  458.           file=fidopaths,
  459.           proto=lsearch
  460.  
  461.   You should only include ifmail chapter if you use ifmail for FIDO
  462.   mails. Note you can also change transport mode from "uux" (ie UUCP)
  463.   to, for example, "smtp" or even 'hardcode the paths to various
  464.   machines or domains' in "/etc/smail/maps/table".
  465.  
  466.   4.6.  transports" file
  467.  
  468.   # local - deliver mail to local users
  469.   # Tell smail to append directly to user mailbox files in the /var/spool/mail
  470.   # directory.
  471.   #local: driver = appendfile,            # append message to a file
  472.   #       -return_path,                   # include a Return-Path: field
  473.   #       local,                          # use local forms for delivery
  474.   #       from,                           # supply a From_ envelope line
  475.   #       unix_from_hack;                 # insert > before From in body
  476.   #
  477.   #       file = /var/spool/mail/${lc:user},      # use this location for Linux
  478.   #                                               # Note, mail spool must be 1777
  479.   #       file = ~/mailfile,              # use this location for better security
  480.   #       group = mail,                   # group to own file for System V
  481.   #       mode = 0660,                    # under System V, group mail can access
  482.   #       suffix = "\n",                  # append an extra newline
  483.   #       append_as_user,
  484.  
  485.   # This allows each user to have a ~/.procmailrc file to control filtering
  486.   # of mail and saving mail from mail lists in separate mailboxes if they wish.
  487.   local:  +inet,
  488.           -uucp,
  489.           driver = pipe,                  # append message to a file
  490.           return_path,                    # include a Return-Path: field
  491.           local,                          # use local forms for delivery
  492.           from,                           # supply a From_ envelope line
  493.           unix_from_hack;                 # insert > before From in body
  494.  
  495.           cmd = "/usr/bin/procmail",      # use procmail for local delivery
  496.           parent_env,                     # environment info from parent addr
  497.           pipe_as_user,                   # use user-id associated with address
  498.           umask = 0022,                   # umask for child process
  499.   #       -ignore_status,                 # exit status should be believed
  500.   #       -ignore_write_errors,           # retry on broken pipes
  501.  
  502.   # pipe - deliver mail to shell commands
  503.   # This is used implicitly when smail encounters addresses which begin with
  504.   # a vertical bar character, such as "|/usr/lib/news/recnews talk.bizarre".
  505.   # The vertical bar is removed from the address before being given to the
  506.   # transport.
  507.   #pipe:  driver = pipe,                  # pipe message to another program
  508.   #       return_path, local, from, unix_from_hack;
  509.   #
  510.   #       cmd = "/bin/sh -c $user",       # send address to the Bourne Shell
  511.   #       parent_env,                     # environment info from parent addr
  512.   #       pipe_as_user,                   # use user-id associated with address
  513.   #       umask = 0022,                   # umask for child process
  514.   #       -log_output,                    # do not log stdout/stderr
  515.   #       ignore_status,                  # exit status may be bogus, ignore it
  516.   #       ignore_write_errors,            # ignore broken pipes
  517.  
  518.   # file - deliver mail to files
  519.   # This is used implicitly when smail encounters addresses which begin with
  520.   # a slash or squiggle character, such as "/usr/info/list_messages" or
  521.   # perhaps "~/Mail/inbox".
  522.   #file:  driver = appendfile,
  523.   #       return_path, local, from, unix_from_hack;
  524.   #
  525.   #       file = $user,                   # file is taken from address
  526.   #       append_as_user,                 # use user-id associated with address
  527.   #       expand_user,                    # expand ~ and $ within address
  528.   #       check_path,
  529.   #       suffix = "\n",
  530.   #       mode = 0644
  531.   # uux - deliver to the rmail program on a remote UUCP site
  532.   #
  533.   # As many as five recipient addresses will be delivered to the remote
  534.   # host in one UUCP transaction.
  535.   uux:    driver = pipe,
  536.           -uucp,
  537.           inet,
  538.   #       uucp,                           # use UUCP-style addressing forms
  539.           from,                           # supply a From_ envelope line
  540.           max_addrs = 5,                  # at most 5 addresses per invocation
  541.           max_chars = 200;                # at most 200 chars of addresses
  542.   # the -r flag prevents immediate delivery, parentheses around the
  543.   # $user variable prevent special interpretation by uux.
  544.           cmd = "/usr/bin/uux - -r -g$grade $host!rmail $((${strip:user})$)",
  545.   #        cmd="/usr/bin/uux - $host!rmail $(($user)$)",
  546.           ignore_write_errors,            # ignore broken pipes
  547.           umask = 0022,
  548.   #       pipe_as_sender,
  549.  
  550.   # uux_one_addr - deliver mail over UUCP to a remote host that can take
  551.   #                one address at a time.
  552.   # This is often necessary when delivering to a site running an unmodified
  553.   # version of 4.1BSD.
  554.   uux_one_addr:
  555.           driver = pipe,
  556.           uucp,                           # use UUCP-style addressing forms
  557.           from;                           # supply a From_ envelope line
  558.   # the -r flag prevents immediate delivery
  559.           cmd = "/usr/bin/uux - -r -g$grade $host!rmail (${strip:user})",
  560.           umask = 0022,
  561.           pipe_as_sender
  562.  
  563.   queueonly:
  564.           driver = pipe;                  # send the message to a pipe
  565.           cmd = "/usr/lib/sendmail -Q -f $sender -bm $user",
  566.                                           # use getmail for local delivery
  567.           user=root,                      # execute getmail as "root"
  568.           group=mail,                     # execute getmail as "mail"
  569.           parent_env,                     # environment info from parent addr
  570.           -pipe_as_user,                  # use user-id associated with address
  571.           umask = 0007,                   # umask for child process
  572.  
  573.   # to deliver the message.  The smtp transport is included only if BSD
  574.   # networking exists.
  575.   # The uucp attribute can be specified for transfers within the UUCP
  576.   # zone.  The inet attribute must be specified for transfers within the
  577.   # Internet.
  578.   # NOTE: This is hardly optimal, a backend should exist which can handle
  579.   #       multiple messages per connection.
  580.   # ALSO: It may be necessary to restrict max_addrs to 100, as this is the
  581.   #       lower limit SMTP requires an implementation to handle for one
  582.   #       message.
  583.   smtp:   driver=tcpsmtp,
  584.           inet,                           # if UUCP_ZONE is not defined
  585.   #       uucp,                           # if UUCP_ZONE is defined
  586.           -max_addrs, -max_chars;         # no limit on number of addresses
  587.  
  588.           short_timeout=5m,               # timeout for short operations
  589.           long_timeout=2h,                # timeout for longer SMTP operations
  590.           service=smtp,                   # connect to this service port
  591.   # For internet use: uncomment the below 4 lines
  592.          use_bind,                       # resolve MX and multiple A records
  593.          defnames,                       # use standard domain searching
  594.          defer_no_connect,               # try again if the nameserver is down
  595.          local_mx_okay,                  # fail an MX to the local host
  596.  
  597.   ifmail:
  598.           from,received,max_addrs=5,max_chars=200,
  599.           driver=pipe;
  600.           pipe_as_sender,
  601.           cmd="/usr/local/bin/ifmail -x9 -r$host $((${strip:user})$)"
  602.  
  603.   You should include an ifmail chapter only if you use ifmail for FIDO
  604.   mails. Apart from that, you shouldn't need to edit anything in this
  605.   file which defines transport agents (like uux, smtp ...) you can use
  606.   as parameters in other config. files.
  607.  
  608.   Note I commented out some parts, like "pipes" or "file", to enhance
  609.   security.
  610.  
  611.   4.7.  maps/" directory
  612.  
  613.   It contains map and table files :
  614.  
  615.   First, map file
  616.  
  617.        #N      foo.bar foo2.bar2
  618.        #S      AT 486/RedHat Linux 1.2.13
  619.        #O      organization
  620.        #C      contact
  621.        #E      administration (email)
  622.        #T      phone
  623.        #P      address
  624.        #R
  625.        #U      hosts connected via uucp
  626.        #W      created/edited by
  627.        #
  628.        hname polux
  629.  
  630.        hname linux.eu.org
  631.  
  632.        hname = polux
  633.        hname = polux.linux.eu.org
  634.  
  635.   Once again, edit this file to match you situation (I'm fed by
  636.   polux.linux.eu.org).
  637.  
  638.   Now table file
  639.  
  640.        *       uux
  641.  
  642.   You can define different transports to different path, for exemple
  643.   "smtp" for the machines in your local network, "uux" (i.e. uucp) for
  644.   the rest of the world or vice-versa (I'm using uucp for any outgoing
  645.   mail, therefore I use "*" !).
  646.  
  647.   4.8.  Other good examples
  648.  
  649.   The previous files are the one I currently use for my site, you
  650.   shouldn't encounter any problem using them as samples/basis for your
  651.   own files.
  652.  
  653.   The following files are provided only as good exemples to configure
  654.   smail a different way.
  655.  
  656.   #ident "@(#) transports,v 1.2 1990/10/24 05:20:46 tron Exp"
  657.  
  658.   # See smail(5) for a complete description of the contents of this file.
  659.  
  660.   # local - deliver mail to local users
  661.   #
  662.   # Tell smail to append directly to user mailbox files in the /usr/mail
  663.   # directory.
  664.   local:  driver = appendfile,            # append message to a file
  665.           return_path,                    # include a Return-Path: field
  666.           local,                          # use local forms for delivery
  667.           from,                           # supply a From_ envelope line
  668.           unix_from_hack;                 # insert > before From in body
  669.  
  670.           file = /usr/mail/${lc:user},    # use this location for System V
  671.           group = mail,                   # group to own file for System V
  672.           mode = 0660,                    # under System V, group mail can access
  673.           suffix = "\n",                  # append an extra newline
  674.           append_as_user,
  675.  
  676.   # pipe - deliver mail to shell commands
  677.   #
  678.   # This is used implicitly when smail encounters addresses which begin with
  679.   # a vertical bar character, such as "|/usr/lib/news/recnews talk.bizarre".
  680.   # The vertical bar is removed from the address before being given to the
  681.   # transport.
  682.   pipe:   driver = pipe,                  # pipe message to another program
  683.           return_path, local, from, unix_from_hack;
  684.  
  685.           cmd = "/bin/sh -c $user",       # send address to the Bourne Shell
  686.           parent_env,                     # environment info from parent addr
  687.           pipe_as_user,                   # use user-id associated with address
  688.           umask = 0022,                   # umask for child process
  689.           -log_output,                    # do not log stdout/stderr
  690.           ignore_status,                  # exit status may be bogus, ignore it
  691.           ignore_write_errors,            # ignore broken pipes
  692.  
  693.   # file - deliver mail to files
  694.   #
  695.   # This is used implicitly when smail encounters addresses which begin with a
  696.   # slash or squiggle character, such as "/usr/info/list_messages" or perhaps
  697.   # "~/Mail/inbox".
  698.   file:   driver = appendfile,
  699.           return_path, local, from, unix_from_hack;
  700.  
  701.           file = $user,                   # file is taken from address
  702.           append_as_user,                 # use user-id associated with address
  703.           expand_user,                    # expand ~ and $ within address
  704.           suffix = "\n",
  705.           mode = 0644
  706.  
  707.   # uux - deliver to the rmail program on a remote UUCP site
  708.   #
  709.   # As many as five recipient addresses will be delivered to the remote host in
  710.   # one UUCP transaction.
  711.   uux:    driver = pipe,
  712.           uucp,                           # use UUCP-style addressing forms
  713.           from,                           # supply a From_ envelope line
  714.           max_addrs = 5,                  # at most 5 addresses per invocation
  715.           max_chars = 200;                # at most 200 chars of addresses
  716.  
  717.           # the -r flag prevents immediate delivery, parentheses around the
  718.           # $user variable prevent special interpretation by uux.
  719.           cmd = "/usr/bin/uux - -r -g$grade $host!rmail $((${strip:user})$)",
  720.           umask = 0022,
  721.           pipe_as_sender
  722.   # uux_one_addr - deliver mail over UUCP to a remote host that can take one
  723.   # address at a time.
  724.   #
  725.   # This is often necessary when delivering to a site running an unmodified
  726.   # version of 4.1BSD.
  727.   uux_one_addr:
  728.           driver = pipe,
  729.           uucp,                           # use UUCP-style addressing forms
  730.           from;                           # supply a From_ envelope line
  731.  
  732.           # the -r flag prevents immediate delivery
  733.           cmd = "/usr/bin/uux - -r -g$grade $host!rmail (${strip:user})",
  734.           umask = 0022, pipe_as_sender
  735.  
  736.   # demand - deliver to a remote rmail program, polling on demand
  737.   demand: driver = pipe,
  738.           uucp, from, max_addrs = 5, max_chars = 200;
  739.  
  740.           # with no -r flag, try to contact remote site immediately
  741.           cmd = "/usr/bin/uux - -g$grade $host!rmail $(($user)$)",
  742.           umask = 0022, pipe_as_sender
  743.  
  744.   # uusmtp - deliver to the rsmtp program on a remote UUCP site
  745.   #
  746.   # Deliver using a simple Batched SMTP protocol to the remote machine.
  747.   # This allows much more arbitrary addresses to be used.  It also
  748.   # removes the limit on recipient addresses per invocation of uux.
  749.   uusmtp: driver = pipe,
  750.           bsmtp,                          # send batched SMTP commands
  751.           -max_addrs,                     # there is no limit on the number or
  752.           -max_chars;                     #   total size of recipient addresses.
  753.  
  754.           # supply -r to prevent immedate delivery, the recipient addresses
  755.           # are stored in the data sent to the standard input of rsmtp.
  756.           cmd = "/usr/bin/uux - -r -g$grade $host!rsmtp",
  757.           umask = 0022, pipe_as_sender
  758.  
  759.   # demand_uusmtp - deliver to a remote rsmtp program, polling on demand
  760.   demand_uusmtp:
  761.           driver = pipe,
  762.           bsmtp, -max_addrs, -max_chars;
  763.  
  764.           # with no -r flag, try to contact remote site immediately
  765.           cmd = "/usr/bin/uux - -g$grade $host!rsmtp",
  766.           umask = 0022, pipe_as_sender
  767.  
  768.   # smtp - deliver using SMTP over TCP/IP
  769.   #
  770.   # Connect to a remote host using TCP/IP and initiate an SMTP conversation to
  771.   # deliver the message.  The smtp transport is included only if BSD networking
  772.   # exists.
  773.  
  774.   # NOTE: It may be necessary to restrict max_addrs to 100, as this is the
  775.   #       lower limit SMTP requires an implementation to handle for one
  776.   #       message.
  777.   smtp:   driver = smtp,
  778.           -max_addrs,
  779.           -max_chars
  780.  
  781.   #ident "@(#) table,v 1.2 1990/10/24 05:20:31 tron Exp"
  782.  
  783.   # This file names the transports that are to be used in delivering
  784.   # to specific hosts from bargw.
  785.  
  786.   #host           transport
  787.   #--------       ---------
  788.   curdsgw         demand_uusmtp   # deliver using batched SMTP
  789.   oldbsd          uux_one_addr    # 4.1BSD sites cannot take more than one addr
  790.   sun             demand          # call sun when their is mail to send
  791.   *               uux             # for all others, poll at intervals
  792.  
  793.   4.9.  Restarting inetd
  794.  
  795.   To run smail as a smtp daemon, add one of the following to
  796.   /etc/inetd.conf:
  797.  
  798.            smtp stream tcp nowait  root  /usr/bin/smtpd smtpd
  799.  
  800.   or:
  801.  
  802.            smtp stream tcp nowait  root  /usr/sbin/tcpd  /usr/sbin/in.smtpd
  803.  
  804.   Outgoing mail gets sent automatically, when using elm.
  805.  
  806.   4.10.  Smail with smtp
  807.  
  808.   Generally, ISPs use smtp, therefore you shouldn't have any problems
  809.   sending your mail. If your internet link is down when you send mail,
  810.   then the mail sits in "/var/spool/smail/input". When the link next
  811.   comes up, "runq" is run which causes the mail to be sent. However,
  812.   receiving mail is the problem since your provider has many clients to
  813.   look after, not only you !
  814.  
  815.   Usually, you can retreive your mail via the POP protocol, see POP
  816.   section below.
  817.  
  818.   5.  Sendmail+IDA
  819.  
  820.   For big sites, sendmail is worth choosing, due to the incredible ease
  821.   of use, but you must decide which you want between sendmail+IDA and
  822.   sendmail 8.x :
  823.  
  824.   ╖  If you use an old kernel (1.0) : sendmail+IDA
  825.  
  826.   ╖  If you use a not so old kernel (1.2) : sendmail+IDA and source code
  827.      editing
  828.  
  829.   ╖  Recent kernel (2.0) will choose sendmail 8.x
  830.  
  831.   Remember, linux newbies or people concerned by security / ease of
  832.   configuration should rather try using smail or qmail, which are easier
  833.   to use and safer.
  834.   5.1.  Source installation
  835.  
  836.   ╖  cd / ; tar -zxvf sendmail5.67b+IDA1.5.tpz
  837.  
  838.   ╖  cd to /usr/local/lib/mail/CF and copy the sample.m4 local.m4 file
  839.      to "yourhostname.m4".
  840.  
  841.   Edit out the distributed hostname, aliases, smarthost and put in the
  842.   correct one for your site. The default file is for a uucp-only site
  843.   who has domainized headers and who talks to a smart host. Then "make
  844.   yourhostname.cf" and move the resulting file to /etc/sendmail.cf
  845.  
  846.   ╖  if you are uucp-only, you do *NOT* need to create any of the tables
  847.      mentioned in the README.linux file.
  848.  
  849.   You'll just have to touch the files so that the Makefile works. Just
  850.   edit the .m4 file, make sendmail.cf and start testing it.
  851.  
  852.   ╖  if you're uucp-only and you talk to sites in addition to your
  853.      "smart-host", you'll need to add uucpxtable entries for each (or
  854.      mail to them will also go through the smart host) and run dbm
  855.      against the revised uucpxtable.
  856.  
  857.   ╖  If you run Rich Braun's original binary distribution of 5.67a,
  858.      you'll need to freeze the configuration if you change your .cf file
  859.      with "/usr/lib/sendmail -bz" to make the changes take effect.
  860.  
  861.   You should also update your version to at least 5.67b since there is a
  862.   nasty security hole in 5.67a and earlier. Another nice thing is that
  863.   if you have mail.debug set and you run syslogd, your incoming and
  864.   outgoing mail messages will get logged. See the "/etc/syslog.conf"
  865.   file for details.
  866.  
  867.   The sources for sendmail+IDA can be found at vixen.cso.uiuc.edu ; they
  868.   require no patching to run under Linux if you're running something
  869.   like a kernel of 1.00.
  870.  
  871.   If you're running a kernel > 1.1.50, you get the fun of reversing most
  872.   of the Linux-specific patches that are now in the vanilla sources.  (I
  873.   *did* told you this sendmail was only for old kernels :-)
  874.  
  875.   It's extremely obvious where this needs to be done : just type "make"
  876.   and when it blows up, go to that line in the sources and comment out
  877.   the Linux-specific code that's in there.
  878.  
  879.   If you're going to run sendmail+IDA, I strongly recommend you go to
  880.   the sendmail5.67b+IDA1.5 version since all required Linux-specific
  881.   patches are now in the vanilla sources and several security holes have
  882.   been plugged that WERE (!!!) in the older version you may have grabbed
  883.   or built before about December 1st, 1993.
  884.  
  885.   Now linux kernel is 2.0, you should use sendmail 8.x insted of
  886.   sendmail+IDA, but I told you'd better choose sendmail 8.x :-)
  887.  
  888.   5.2.  The sendmail.m4 file
  889.  
  890.   Sendmail+IDA requires you to set up a sendmail.m4 file rather than
  891.   editing the sendmail.cffile directly.  The nice thing about this is
  892.   that it is simple to set up mail configurations that are extremely
  893.   difficult (if not totally impossible for most people to set up
  894.   correctly) in smail or traditional sendmail.
  895.  
  896.   The sendmail.m4 file that corresponds to the above smail example looks
  897.   like the following:
  898.  
  899.     dnl #------------------ SAMPLE SENDMAIL.M4 FILE ------------------
  900.     dnl #
  901.     dnl # (the string 'dnl' is the m4 equivalent of commenting out a line)
  902.     dnl #
  903.     dnl # you generally don't want to override LIBDIR from the compiled in paths
  904.     dnl #define(LIBDIR,/usr/local/lib/mail)dnl    # where all support files go
  905.     define(LOCAL_MAILER_DEF, mailers.linux)dnl    # mailer for local delivery
  906.     define(POSTMASTERBOUNCE)dnl                   # postmaster gets bounces
  907.     define(PSEUDODOMAINS, BITNET UUCP)dnl         # don't try DNS on these
  908.     dnl #
  909.     dnl #-------------------------------------------------------------
  910.     dnl #
  911.     dnl # names we're known by
  912.     define(PSEUDONYMS, myhostname.subdomain.domain myhostname.UUCP)
  913.     dnl #
  914.     dnl # our primary name
  915.     define(HOSTNAME, myhostname.subdomain.domain)
  916.     dnl #
  917.     dnl # our uucp name
  918.     define(UUCPNAME, myhostname)dnl
  919.     dnl #
  920.     dnl #-------------------------------------------------------------
  921.     dnl #
  922.     define(UUCPNODES, |uuname|sort|uniq)dnl       # our uucp neighbors
  923.     define(BANGIMPLIESUUCP)dnl                    # make certain that uucp
  924.     define(BANGONLYUUCP)dnl                       #  mail is treated correctly
  925.     define(RELAY_HOST, my_uucp_neighbor)dnl       # our smart relay host
  926.     define(RELAY_MAILER, UUCP-A)dnl               # we reach moria via uucp
  927.     dnl #
  928.     dnl #--------------------------------------------------------------------
  929.     dnl #
  930.     dnl # the various dbm lookup tables
  931.     dnl #
  932.     define(ALIASES, LIBDIR/aliases)dnl            # system aliases
  933.     define(DOMAINTABLE, LIBDIR/domaintable)dnl    # domainize hosts
  934.     define(PATHTABLE, LIBDIR/pathtable)dnl        # paths database
  935.     define(GENERICFROM, LIBDIR/generics)dnl       # generic from addresses
  936.     define(MAILERTABLE, LIBDIR/mailertable)dnl    # mailers per host or domain
  937.     define(UUCPXTABLE, LIBDIR/uucpxtable)dnl      # paths to hosts we feed
  938.     define(UUCPRELAYS, LIBDIR/uucprelays)dnl      # short-circuit paths
  939.     dnl #
  940.     dnl #--------------------------------------------------------------------
  941.     dnl #
  942.     dnl # include the 'real' code that makes it all work
  943.     dnl # (provided with the source code)
  944.     dnl #
  945.     include(Sendmail.mc)dnl                         # REQUIRED ENTRY !!!
  946.     dnl #
  947.     dnl #------------ END OF SAMPLE SENDMAIL.M4 FILE -------
  948.  
  949.   5.3.  Defining a local mailer
  950.  
  951.   Unlike most Unix distributions, Linux does not come with a local mail
  952.   delivery agent by default. Now, deliver or procmail is generally
  953.   installed, so no complexity will be added to this already very complex
  954.   setup. I recommend using the commonly available deliver or procmail
  955.   programs, which can be optional packages in a some Linux
  956.   distributions.
  957.  
  958.   In order to do so, you need to define a LOCAL_MAILER_DEF in the
  959.   sendmail.m4 file that points to a file that looks like:
  960.  
  961.     # -- /usr/local/lib/mail/mailers.linux --
  962.     #     (local mailers for use on Linux )
  963.     Mlocal, P=/usr/bin/deliver, F=SlsmFDMP, S=10, R=25/10, A=deliver $u
  964.     Mprog,  P=/bin/sh,       F=lsDFMeuP,   S=10, R=10, A=sh -c $u
  965.  
  966.   There is a also built-in default for deliver in the Sendmail.mc file
  967.   that gets included into the sendmail.cf file. To specify it, you would
  968.   not use the mailers.linux file but would instead define the following
  969.   in your sendmail.m4 file:
  970.  
  971.      dnl --- (in sendmail.m4) ---
  972.      define(LOCAL_MAILER_DEF, DELIVER)dnl       # mailer for local delivery
  973.  
  974.   Unfortunately, Sendmail.mc assumes deliver is installed in /bin, which
  975.   is not the case with Slackware1.1.1 (which installs it in /usr/bin).
  976.   In that case you'd need to either fake it with a link or rebuild
  977.   deliver from sources so that it resides in /bin. Please note procmail
  978.   is generally better than deliver, for example for mail filtering.
  979.  
  980.   5.4.  The sendmail+IDA dbm tables
  981.  
  982.   Setting up special behavior for sites or domains is done through a
  983.   number of optional dbm tables rather than editing the sendmail.cf file
  984.   directly.
  985.  
  986.   Refer to the July-1994 issue of Linux Journal (if you can still find
  987.   it :-), to the docs in the sources, or to the sendmail chapter in the
  988.   newest version of the Linux DOC Project Networking Administration
  989.   Guide which will be available real-soon-now for more details.
  990.  
  991.   ╖  mailertable   - defines special behavior for remote hosts or
  992.      domains.
  993.  
  994.   ╖  uucpxtable    - forces UUCP delivery of mail to hosts that are in
  995.      DNS format.
  996.  
  997.   ╖  pathtable     - defines UUCP bang-paths to remote hosts or domains.
  998.  
  999.   ╖  uucprelays    - short-circuits the pathalias path to well-known
  1000.      remote hosts.
  1001.  
  1002.   ╖  genericfrom   - converts internal addresses into generic ones
  1003.      visible to the outside world.
  1004.  
  1005.   ╖  xaliases      - converts generic addresses to/from valid internal
  1006.      ones.
  1007.  
  1008.   ╖  decnetxtable  - converts RFC-822 addresses to DECnet-style
  1009.      addresses.
  1010.  
  1011.   5.5.  So which entries are really required?
  1012.  
  1013.   When not using any of the optional dbm tables, sendmail delivers mail
  1014.   via the RELAY_HOST and RELAY_MAILER) defined in the sendmail.m4 file
  1015.   used to generate sendmail.cf. It is easily possible to override this
  1016.   behavior through entries in the domaintable or uucpxtable.
  1017.  
  1018.   A generic site that is on Internet and speaks Domain Name Service, or
  1019.   one that is UUCP-only and forwards all mail via UUCP through a smart
  1020.   RELAY_HOST, probably does not need any specific table entries at all.
  1021.  
  1022.   Virtually all systems should set the DEFAULT_HOST and PSEUDONYMS
  1023.   macros, which define the canonical site name and aliases it is known
  1024.   by.
  1025.  
  1026.   If all you have is a relay host and relay mailer, you don't need to
  1027.   set these defaults since it works automagically. UUCP hosts will
  1028.   probably also need to set UUCPNAME to their official UUCP name.
  1029.  
  1030.   They will also probably set RELAY_MAILER and RELAY_HOST which enable
  1031.   smart-host routing through a mail relay.
  1032.  
  1033.   The mail transport to be used is defined in RELAY_MAILER and should
  1034.   usually be UUCP-A for UUCP sites. If your site is SMTP-only and talks
  1035.   `Domain Name Service', you would change the RELAY_MAILER.
  1036.  
  1037.   If you're a SLIP site, you might want to take the easy way out and
  1038.   just forward all outgoing mail to your service provider to do the
  1039.   right thing with.  To do so, you'd want to define ISOLATED_DOMAINS and
  1040.   VALIDATION_DOMAINS to be your domain, you'd also want to define
  1041.   RELAY_HOST to be your service provider and RELAY_MAILER to be TCP. Of
  1042.   course, you want to ask permission before you set any system up as
  1043.   your general purpose relay.
  1044.  
  1045.   5.6.  Sendmail 8.x
  1046.  
  1047.   Sendmail 8.7.x from Berkeley was the latest major revision after
  1048.   sendmail5. It had wonderful built-in support for building under Linux
  1049.   : just "make linux" and all was set.
  1050.  
  1051.   You'll probably be best served by grabbing one of the various binary
  1052.   distributions off of the usual Linux archive sites rather than
  1053.   fighting things like Berkeley dbm yourself.
  1054.  
  1055.   There's a nice distribution of sendmail 8.6.12 from Jason Haar -
  1056.   j.haar at lazerjem.demon.co.uk  on sunsite.unc.edu in
  1057.   /pub/Linux/system/Mail/delivery/sendmail-8.6.12-bin.tgz that has the
  1058.   source documentation and a very nice quickie description of how to run
  1059.   sendmail v8 for common configurations.
  1060.  
  1061.   The bottom line with sendmail v8 is that you want to configure the
  1062.   bare minimum necessary to get the job done ; the following is an
  1063.   example that should get you close at least.
  1064.  
  1065.   5.7.  A sample 8.7.x mc file
  1066.  
  1067.   Much like sendmail+IDA, sendmail v8 uses m4 to process a config file
  1068.   into a full sendmail.cf that sendmail uses.  The following is my
  1069.   current mc file for my site (ppp to Internet for outgoing mail, uucp
  1070.   for incoming mail).
  1071.  
  1072.           dnl divert(-1)
  1073.           #---------------------------------------------------------------------
  1074.           #
  1075.           # this is the .mc file for a linux host that's set up as follows:
  1076.           #
  1077.           #       - connected to Internet for outbound mail (ppp here)
  1078.           #       - connected via UUCP for incoming mail
  1079.           #       - domainized headers
  1080.           #       - no local mailer (use 'deliver' instead)
  1081.           #       - no DNS running so don't canonicalize outgoing via DNS
  1082.           #       - all non-local outbound mail goes to the RELAY_HOST over smtp
  1083.           #           (we run ppp and let our service provider do the work)
  1084.           #
  1085.           #                                       vds 3/31/95
  1086.           #
  1087.           #---------------------------------------------------------------------
  1088.           include(`../m4/cf.m4')
  1089.           VERSIONID(`linux nodns relays to slip service provider smarthost')dnl
  1090.           Cwmyhostname.myprimary.domain myhostname.UUCP localhost
  1091.           OSTYPE(linux)
  1092.           FEATURE(nodns)dnl
  1093.           FEATURE(always_add_domain)dnl
  1094.           FEATURE(redirect)
  1095.           FEATURE(nocanonify)
  1096.           dnl MAILER(local)dnl
  1097.           MAILER(smtp)dnl
  1098.           MAILER(uucp)dnl
  1099.           define(`RELAY_HOST', smtp:my.relay.host.domain)
  1100.           define(`SMART_HOST', smtp:my.relay.host.domain)
  1101.           define(`UUCP_RELAY', smtp:my.relay.host.domain)
  1102.           define(`LOCAL_MAILER_PATH', `/bin/deliver')
  1103.           define(`LOCAL_MAILER_ARGS', `deliver $u')
  1104.  
  1105.   5.8.  Sendmail v8 tidbits
  1106.  
  1107.   There are a few differences I suppose to the 'IDA bigots' among us.
  1108.   So far, I've found the following:
  1109.  
  1110.   Instead of 'runq', you type 'sendmail -q' to run the queue !
  1111.  
  1112.   5.9.  Local Delivery Agents
  1113.  
  1114.   Unlike most operating systems, Linux did not have mail "built-in" :
  1115.   you needed a program to deliver the local mail, like "lmail",
  1116.   "procmail" or "deliver".
  1117.  
  1118.   However, every recent distribution includes a local mailer !
  1119.  
  1120.   Documentation for how to use either for local delivery is in the
  1121.   sendmail5.67b+IDA1.5 binary release (on sunsite) mentioned above.
  1122.  
  1123.   6.  POP mail
  1124.  
  1125.   This section also concerns IMAP, not very different from POP.
  1126.  
  1127.   6.1.  History
  1128.  
  1129.   On a workstation network, mail has always been a problem:
  1130.  
  1131.   ╖  Either you use "user@computer.foo.com" with problems when
  1132.      "computer" is down, make your network known to the people outside,
  1133.      have different addresses for a same person switching to another
  1134.      computer, ...
  1135.  
  1136.   ╖  Either you take a mail hub, "mailhost.foo.com" with rules for
  1137.      rewriting, so every user seems to post from the same address, even
  1138.      if they are on different computers.
  1139.  
  1140.   But in that case, how can user read their mail ? Using a rsh with elm
  1141.   ? :-) It would overload our mail hub ! One method was forwarding or
  1142.   UUCP, smtp, etc. but it's too complicated.
  1143.  
  1144.   Then came POP/IMAP, both with security problems at the beginning, now
  1145.   fixed using ssh on new versions) : a mail program has sometimes to be
  1146.   set locally (like sendmail, smail, qmail if, for example, you use elm,
  1147.   but mozilla will avoid that !) however, getting and sending Email is
  1148.   simpler.
  1149.  
  1150.   6.2.  Getting mail
  1151.  
  1152.   Here come POP's main drawbacks : the password is sent as a clear text
  1153.   on the network, and some mail readers just don't know POP : you must
  1154.   choose a POP-aware mailer, like Pine, Emacs, Netscape, Mutt ...
  1155.  
  1156.   Password problem can be solved creating a crypted "channel" to have
  1157.   POP on it or using APOP or RPOP extensions. The mail reader problem
  1158.   can be solved either by changing mail reader (mozilla is POP ready, as
  1159.   are Emacs and pine) or by using a POP "mail sucker" with a local mail
  1160.   program.
  1161.  
  1162.   gwpop (a Good Way to POP) is worth using since it creates a crypted
  1163.   "channel" and puts mail directly in the "spool". However, it depends
  1164.   on Perl ...
  1165.  
  1166.   I can also recommand fetchmail, which is actively supported.
  1167.  
  1168.   Otherwise you can use one of the various pop clients available for
  1169.   linux, for exaple if your login is john and your password
  1170.   PrettySecret, you will run :
  1171.  
  1172.        $ popclient -3 -v mail.acme.net -u john -p "PrettySecret" -k -o JOHN-INET-MAIL
  1173.  
  1174.   (see popclient manpage for the exact meanings of the above options !)
  1175.  
  1176.   6.3.  Sending mail
  1177.  
  1178.   For this, you must use smtp-aware mail software, like qmail, sendmail,
  1179.   smail or mozilla (this one does everything : mail reader, POP receive,
  1180.   smtp send !)
  1181.  
  1182.   Go to one of the previous sections to install and configure the one
  1183.   you like best. Then, will you will reach "Testing", try to send some
  1184.   mail to a local account on the mail hub.
  1185.  
  1186.   6.4.  Reading mail
  1187.  
  1188.   If your program doesn't do everything itself, you can install elm,
  1189.   pgp, mush, pine ... many good programs are freely available for linux
  1190.   platforms !
  1191.  
  1192.   6.5.  Testing
  1193.  
  1194.   To check your mail server has pop, try :
  1195.  
  1196.        $ telnet mailhost 110
  1197.  
  1198.   If it works, you will get something like "OK Pop server (...)
  1199.   starting" : type "quit" !
  1200.  
  1201.   To install a ssh crypted "channel", first test your mail server typing
  1202.   :
  1203.  
  1204.        $ ssh mailhost date
  1205.  
  1206.   If you get the date, you should be OK. Please note ssh will not ask
  1207.   for a password, therefore you must create a ".shosts" file on the mail
  1208.   server, containing client's name. To test ssh port redirection (which
  1209.   gwpop uses), type :
  1210.  
  1211.        $ ssh -n -f -L 12314:localhost:110 mailhost sleep 30
  1212.  
  1213.        then
  1214.  
  1215.        $ telnet localhost 12314
  1216.  
  1217.   Then will you hopefully see mail hub's pop banner. If you don't use
  1218.   ssh, don't forget to comment out $ssh on gwpop script. To check
  1219.   whether procmail is running, try "procmail -v"
  1220.  
  1221.   6.6.  Using
  1222.  
  1223.   Now you can edit gwpop Perl script to check everything is ok, then run
  1224.   gwpop :
  1225.  
  1226.        $ gwpop -v your-username
  1227.        POP password on mailhost: yoursecretpasword
  1228.  
  1229.   If gwpop "error messages" are normal, the mail from mail hub will be
  1230.   downloaded to your local machine whereever you told gwpop to put it.
  1231.   (please test with some mail !).
  1232.  
  1233.   You can also use gwpop as a daemon :
  1234.  
  1235.        $ gwpop -d $HOME/tmp your-username
  1236.  
  1237.   gwpop messages are then sent to syslog and gwpop will run endlessly ;
  1238.   a "HUP" signal will force gwpop to get your mail.
  1239.  
  1240.   You can get POP software here used on :
  1241.  
  1242.        ftp://ftp.pasteur.fr/pub/Network/gwpop
  1243.        ftp://ftp.informatik.rwth-aachen.de/pub/packages/procmail
  1244.        http://www.cs.hut.fi/ssh/
  1245.  
  1246.   7.  Mail "user agents"
  1247.  
  1248.   This section contains information related to "user agents", which
  1249.   means the software the user sees and uses. This software relies on the
  1250.   "transport agents" mentioned above. Many other mail "User Agents" are
  1251.   available now (pine, mush ...) but I haven't found any linux-specific
  1252.   information to tell on them. Please tell me if I'm missing something !
  1253.  
  1254.   7.1.  Elm
  1255.  
  1256.   Elm compiles, installs and runs flawlessly under Linux. For more
  1257.   information, see the elm sources and installation instructions. Elm
  1258.   and filter need to be mode 2755 (group mail) with /var/spool/mail mode
  1259.   775 and group mail.
  1260.  
  1261.   If you use a binary distribution, you'll need to create a
  1262.   "/usr/local/lib/elm/elm.rc" file to override the compiled-in hostname
  1263.   and domain information:
  1264.  
  1265.   ╖  replace "subdomain.domain" with your domain name replace
  1266.  
  1267.   ╖  "myhostname" with you un-domainized hostname replace
  1268.  
  1269.           #---------- /usr/local/lib/elm/elm.rc ------------------
  1270.           #
  1271.           # this is the unqualified hostname
  1272.           hostname = myhostname
  1273.           #
  1274.           # this is the local domain
  1275.           hostdomain = subdomain.domain
  1276.           #
  1277.           # this is the fully qualified hostname
  1278.           hostfullname = myhostname.subdomain.domain
  1279.           #
  1280.           #--------------------------------------------------------
  1281.  
  1282.   One thing you want to be aware of is that if you have Elm compiled to
  1283.   be MIME enabled, you need metamail installed and in your path or Elm
  1284.   will not be able to read MIME mail you've received. Metamail is
  1285.   available on thumper.bellcore.com and of course via "archie".
  1286.  
  1287.   In the "too cool to be true" category, there is a distribution of
  1288.   Elm-2.4.24 that is "PGP-aware". To try it, grab the file
  1289.   ftp://ftp.viewlogic.com/pub/elm-2.4pl24pgp3.tar.gz, which is elm2.4.24
  1290.   with PGP hooks added. You configure and build it the same way you do
  1291.   normal Elm, which means you probably need to add the patches mentioned
  1292.   above. For what it's worth, I run it here and like it a lot. Of
  1293.   course, there must be more recent versions available, including elm-
  1294.   ME+.
  1295.  
  1296.   While this item is not Linux-specific, it's perceived (wrongly) to be
  1297.   a nagging Elm bug nevertheless.  We've heard that Elm sometimes fails
  1298.   with a message that it's unable to malloc() some massive number of
  1299.   bytes.  The identified workaround is to remove the post-processed
  1300.   global mail aliases (aliases.dir and aliases.pag).
  1301.  
  1302.   THIS IS NOT A BUG IN ELM, it's an error in configuration of Elm by
  1303.   whomever you got your binary distribution of Elm from.
  1304.  
  1305.   Elm has an enhanced and non-compatible, format for aliases ; you need
  1306.   to ensure that the path Elm uses for aliases is different from the
  1307.   path sendmail/smail uses. From the volume of reports of this problem,
  1308.   it's apparent that at least one major distribution 'on the street' has
  1309.   in the past been misconfigured. (from  scot at catzen.gun.de (Scot W.
  1310.   Stevenson) )
  1311.  
  1312.   The current metamail package requires csh for some of its scripts.
  1313.   Failure to have csh (or tcsh) will cause most interesting errors...
  1314.  
  1315.   7.2.  Mailx
  1316.  
  1317.   Save yourself the pain : just go and grab the mailx kit from Slackware
  1318.   2.1.0 or later, which has a nice implementation of mailx5.5. If you're
  1319.   into building from sources, mailx v5.5 compiles without patching under
  1320.   Linux if you have "pmake" installed. If anybody is still using it, I
  1321.   strongly recommend removing the old "edmail" stuff from SLS1.00 and
  1322.   replacing it with mailx.
  1323.  
  1324.   7.3.  Other user agents
  1325.  
  1326.   The following also are known to run under Linux.  Consult "archie" for
  1327.   details regarding how to find them...
  1328.  
  1329.   ╖  Pine      - from the Univ. of Washington
  1330.  
  1331.   ╖  Metamail  - allows MIME support
  1332.  
  1333.   ╖  mh        - yet another way to handle mail
  1334.  
  1335.   ╖  deliver   - file/process mail based on rules
  1336.  
  1337.   ╖  procmail  - file/process mail based on rules
  1338.  
  1339.   ╖  Majordomo - manages e-mail lists
  1340.  
  1341.   ╖  Mserv     - provide files-by-mail
  1342.  
  1343.   8.  Acknowledgements
  1344.  
  1345.   The following people have helped in the assembly of the information
  1346.   and experience that helped make this document possible:
  1347.  
  1348.   Steve Robbins, Ian Kluft, Rich Braun, Ian Jackson, Syd Weinstein, Ralf
  1349.   Sauther, Martin White, Matt Welsh, Ralph Sims, Phil Hughes, Scot
  1350.   Stevenson, Neil Parker, Stephane Bortzmayer and especially many thanks
  1351.   to Vince Shankan for his huge contribution.
  1352.  
  1353.   If I forgot anybody, my apologies : just Email me !
  1354.  
  1355.